package com.ruoyi.crm.mapper;

import com.ruoyi.crm.domain.DictData;
import org.apache.ibatis.annotations.Param;
import org.springframework.data.domain.Pageable;

import java.util.List;

/**
 * 字典数据表(DictData)表数据库访问层
 *
 * @author makejava
 * @since 2022-06-24 11:12:34
 */
public interface DictDataMapper {

	/**
	 * 通过ID查询单条数据
	 *
	 * @param dictCode 主键
	 * @return 实例对象
	 */
	DictData queryById(Long dictCode);

	/**
	 * 查询指定行数据
	 *
	 * @param dictData 查询条件
	 * @param pageable 分页对象
	 * @return 对象列表
	 */
	List<DictData> queryAllByLimit(DictData dictData, @Param("pageable") Pageable pageable);

	/**
	 * 统计总行数
	 *
	 * @param dictData 查询条件
	 * @return 总行数
	 */
	long count(DictData dictData);

	/**
	 * 新增数据
	 *
	 * @param dictData 实例对象
	 * @return 影响行数
	 */
	int insert(DictData dictData);

	/**
	 * 批量新增数据（MyBatis原生foreach方法）
	 *
	 * @param entities List<DictData> 实例对象列表
	 * @return 影响行数
	 */
	int insertBatch(@Param("entities") List<DictData> entities);

	/**
	 * 批量新增或按主键更新数据（MyBatis原生foreach方法）
	 *
	 * @param entities List<DictData> 实例对象列表
	 * @return 影响行数
	 * @throws org.springframework.jdbc.BadSqlGrammarException 入参是空List的时候会抛SQL语句错误的异常，请自行校验入参
	 */
	int insertOrUpdateBatch(@Param("entities") List<DictData> entities);

	/**
	 * 修改数据
	 *
	 * @param dictData 实例对象
	 * @return 影响行数
	 */
	int update(DictData dictData);

	/**
	 * 通过主键删除数据
	 *
	 * @param dictCode 主键
	 * @return 影响行数
	 */
	int deleteById(Long dictCode);

	List<DictData> selectCommunicationPoint(@Param("communicationPoint") String communicationPoint);

	DictData selectBackBusinessStatus(@Param("busReasonsId") String busReasonsId);
}

